<?php

function index() {
    global $contenido;

    $dbc = conectarBD();
    $resultado = pg_query($dbc, "SELECT * FROM promocion;");
    if (!$resultado) {

        $contenido["error"] = "No se ha podido contactar a la base de datos.";
    } else {
        $promociones = pg_fetch_all($resultado);
        if (!$promociones)
            $contenido["info"] = "No hay promociones en la base de datos.";
        else
            $contenido["promociones"] = $promociones;
    }
    pg_close($dbc);
}

function view() {
    global $contenido;

    $id_promo = @$_GET["id_promo"];
    if (!$id_promo) {
        $contenido["error"] = "Debe especificar la identificación de la promoción.";
    } else {
        $dbc = conectarBD();
        pg_prepare($dbc, "delete_query", "SELECT * FROM promocion WHERE id_promo = $1;");
        $resultado = pg_execute($dbc, "delete_query", array($id_promo));
        $resultadoArray = pg_fetch_all($resultado);
        pg_close($dbc);
        if (!$resultado || !$resultadoArray) {
            $contenido["error"] = "No se ha encontrado una promoción con la identificación dada.";
        } else {
            $contenido["promocion"] = $resultadoArray[0];
        }
    }
}

function create() {
    Response::$view = "form";
}

function edit() {
    global $contenido;
    view();
    Response::$view = "form";
}

function persist() {
    global $contenido;
    $_GET["id_promo"] = $_POST["id_promo"];
    view();

    $dbc = conectarBD();
    if (!array_key_exists("promocion", $contenido)) {
        $consulta = "INSERT INTO promocion VALUES(".$_POST["id_promo"].",".$_POST["descripcion"].",".$_POST["fecha_inicio"].",".$_POST["fecha_termino"].");";
        pg_prepare($dbc, "persist_query", "INSERT INTO promocion VALUES($1,$2,$3,$4)");
    } else {
        $consulta = "UPDATE promocion SET descripcion=".$_POST["descripcion"].",fecha_inicio=".$_POST["fecha_inicio"].",fecha_termino=".$_POST["fech_termino"]." WHERE id_promo=".$_POST["id_promo"].";";
        pg_prepare($dbc, "persist_query", "UPDATE promocion SET descripcion=$2,fecha_inicio=$3,fecha_termino=$4 WHERE id_promo=$1");
    }
    
    $resultado = pg_execute($dbc, "persist_query", $_POST);
    pg_close($dbc);
    if (!$resultado || $resultado == 0) {
        $contenido["error"] = "No se ha podido guardar el promocion.";
    } else {
        $contenido = array();
        $contenido["exito"] = "Los datos del promocion se han guardado exitosamente.";
        //guardar log
        $log = guardarEnLog($consulta);
    }

    index();
    Response::$view = "index";
}

function delete() {
    global $contenido;

    $id_promo = @$_POST["id_promo"];
    if (!$id_promo) {
        $contenido["error"] = "Debe especificar el número de identificación de la promocion.";
    } else {
        $dbc = conectarBD();
        $consulta = "DELETE FROM promocion WHERE id_promo = ".$id_promo.";";
        pg_prepare($dbc, "delete_query", "DELETE FROM promocion WHERE id_promo = $1");
        $resultado = pg_execute($dbc, "delete_query", array($id_promo));
        pg_close($dbc);
        if (!$resultado || pg_affected_rows($resultado) == 0) {
            $contenido["error"] = "No se ha encontrado una promoción con el número de documento indicado.";
        } else {
            $contenido["alerta"] = "Se ha eliminado correctamente la promocion especificado.";
            //guardar log
            $log = guardarEnLog($consulta);
        }
    }

    index();
    Response::$view = "index";
}

?>
